热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python操作MySQL(pymysql模块)详解及示例代码

本文介绍了使用Python操作MySQL数据库的方法,详细讲解了pymysql模块的安装和连接MySQL数据库的步骤,并提供了示例代码。内容涵盖了创建表、插入数据、查询数据等操作,帮助读者快速掌握Python操作MySQL的技巧。


目录

python连接mysql数据库

操作表与数据




详解

python连接mysql数据库


pymysql是一个第三方模块,需要通过pip install pymysql进行安装。



    import pymysql


    # 连接mysql数据库
    cOnn= pymysql.connect(host='mysql服务器ip',
                          port='mysql服务器端口(默认为3306)',
                          user='mysql服务器用户名',
                          password='mysql服务器用户密码',  
                          database='mysql服务器数据库',
                          charset='utf8')  # 注意:charset='utf8' 不能写成utf-8




    # 使用 cursor()方法 创建一个游标对象 cursor
    cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多

    (左右滑动查看完整python代码)




    操作表与数据


    创建表


      import pymysql


      # 连接mysql数据库
      cOnn= pymysql.connect(host='mysql服务器ip',
                            port='mysql服务器端口(默认为3306)',
                            user='mysql服务器用户名',
                            password='mysql服务器用户密码',
                            database='mysql服务器数据库',
                            charset='utf8')




      # 使用 cursor()方法 创建一个游标对象 cursor
      cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
      # cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多




      # 使用 execute()方法 执行sql,如果表存在则删除
      cursor.execute("DROP TABLE IF EXISTS user")


      # 创建表
      sql = '''CREATE TABLE user (
              NAME CHAR(20) NOT NULL,
              AGE INT,  
              SEX CHAR(1),
              INCOME FLOAT)'''


      # 执行sql
      cursor.execute(sql)


      # 关闭游标
      cursor.close()


      # 关闭数据库连接
      conn.close()

      (左右滑动查看完整python代码)




      操作数据(查询)


        import pymysql


        # 连接mysql数据库
        cOnn= pymysql.connect(host='mysql服务器ip',
                              port='mysql服务器端口(默认为3306)',
                              user='mysql服务器用户名',
                              password='mysql服务器用户密码',
                              database='mysql服务器数据库',
                              charset='utf8')




        # 使用 cursor()方法 创建一个游标对象 cursor
        cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
        # cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多




        sql = "SELECT * FROM user WHERE INCOME > %s" % (1000)
        try:
           cursor.execute(sql)  # 执行SQL语句
           print(cursor.rowcount)  # 获取查出多少行结果
           print(cursor.fetchone())  # 获取一条结果
           print(cursor.fetchmany(10))  # 获取10条结果
           print(cursor.fetchall())  # 获取全部结果
        except Exception as e:
           print(f"SQL执行失败:{e}")




        # 关闭游标
        cursor.close()


        # 关闭数据库连接
        conn.close()

        (左右滑动查看完整python代码)




        操作数据(增删改)


          import pymysql


          # 连接mysql数据库
          cOnn= pymysql.connect(host='mysql服务器ip',
                                port='mysql服务器端口(默认为3306)',
                                user='mysql服务器用户名',
                                password='mysql服务器用户密码',
                                database='mysql服务器数据库',
                                charset='utf8')


          cursor = conn.cursor()  # 创建一个游标对象


          # 增
          sql = "INSERT INTO user(NAME,AGE, SEX, INCOME) \
                VALUES (%s,  %s,  %s,  %s )" % \
                ('pamela', 18, 'F', 1000)


          # 删
          sql = "DELETE FROM user WHERE AGE > %s" % (20)


          # 改
          sql = "UPDATE user SET AGE = AGE + 1 WHERE SEX = '%s'" % ('M')


          try:
             cursor.execute(sql)  # 执行SQL语句
             conn.commit()  # 提交到数据库执行,对存储的数据修改后需要commit
          except Exception as e:
             print(f"SQL执行失败:{e}")
             conn.rollback()  # 如果发生错误则回滚




          cursor.close()  # 关闭游标


          conn.close()  # 关闭数据库连接

          (左右滑动查看完整python代码)




          注意:sql注入问题


          给sql语句传参数,要注意sql注入的问题,传参数不要通过字符串拼接,要通过execute方法来传。


            import pymysql


            # 连接mysql数据库
            cOnn= pymysql.connect(host='mysql服务器ip',
            port='mysql服务器端口(默认为3306)',
            user='mysql服务器用户名',
            password='mysql服务器用户密码',
            database='mysql服务器数据库',
            charset='utf8')
            cursor = conn.cursor() # 创建一个游标对象,查询返回元组


            # sql = "SELECT * FROM user WHERE INCOME > %s" % (1000)
            sql = "SELECT * FROM user WHERE INCOME > %s"
            try:
            cursor.execute(sql, (1000,)) # 执行SQL语句,在第二个参数中传参(把所有参数放在一个元组中)
            except Exception as e:
            print(f"SQL执行失败:{e}")




            cursor.close() # 关闭游标


            conn.close() # 关闭数据库连接

            (左右滑动查看完整python代码)




            其他


            数据备份


              语法:
              备份数据(在cmd命令行直接执行)
              mysqldump -h服务器 -u用户名 -p密码 数据库名 > 备份文件.sql




              #单库备份
              mysqldump -h127.0.0.1 -uroot -p123 db1 > db1.sql
              mysqldump -h127.0.0.1 -uroot -p123 db1 table1 table2 > db1-table1-table2.sql


              #多库备份
              mysqldump -h127.0.0.1 -uroot -p123 --databases db1 db2 db3 > db1_db2_db3.sql


              #备份所有库
              mysqldump -h127.0.0.1 -uroot -p123 --all-databases > all.sql

              (左右滑动查看完整内容)




              数据恢复


                语法:
                恢复数据(在mysql中执行命令)
                切换到一个要备份的数据库中
                source 备份文件.sql




                #方法一:
                命令行:
                mysql -uroot -p123 all.sql


                #方法二:
                mysql中:
                use db1;
                SET SQL_LOG_BIN=0;   #关闭二进制日志,只对当前session生效
                source /root/db1.sql

                (左右滑动查看完整内容)




                事务和锁


                  begin;  # 开启事务
                  select * from user where NAME = 'pamela' for update;  # 查询,for update添加行级锁(select语句后面加一个for update)
                  update user set INCOME=10000 where NAME = 'pamela'; # 完成更新
                  commit;  # 提交事务,释放行级锁

                  (左右滑动查看完整内容)






                  推荐阅读
                  • WhenIusepythontoapplythepymysqlmoduletoaddafieldtoatableinthemysqldatabase,itdo ... [详细]
                  • sklearn数据集库中的常用数据集类型介绍
                    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
                  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
                  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
                  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
                  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
                    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
                  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
                  • Postgresql备份和恢复的方法及命令行操作步骤
                    本文介绍了使用Postgresql进行备份和恢复的方法及命令行操作步骤。通过使用pg_dump命令进行备份,pg_restore命令进行恢复,并设置-h localhost选项,可以完成数据的备份和恢复操作。此外,本文还提供了参考链接以获取更多详细信息。 ... [详细]
                  • 本文介绍了在使用Laravel和sqlsrv连接到SQL Server 2016时,如何在插入查询中使用输出子句,并返回所需的值。同时讨论了使用CreatedOn字段返回最近创建的行的解决方法以及使用Eloquent模型创建后,值正确插入数据库但没有返回uniqueidentifier字段的问题。最后给出了一个示例代码。 ... [详细]
                  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
                  • 开源Keras Faster RCNN模型介绍及代码结构解析
                    本文介绍了开源Keras Faster RCNN模型的环境需求和代码结构,包括FasterRCNN源码解析、RPN与classifier定义、data_generators.py文件的功能以及损失计算。同时提供了该模型的开源地址和安装所需的库。 ... [详细]
                  • Python已成为全球最受欢迎的编程语言之一,然而Python程序的安全运行存在一定的风险。本文介绍了Python程序安全运行需要满足的三个条件,即系统路径上的每个条目都处于安全的位置、"主脚本"所在的目录始终位于系统路径中、若python命令使用-c和-m选项,调用程序的目录也必须是安全的。同时,文章还提出了一些预防措施,如避免将下载文件夹作为当前工作目录、使用pip所在路径而不是直接使用python命令等。对于初学Python的读者来说,这些内容将有所帮助。 ... [详细]
                  • 本文介绍了协程的概念和意义,以及使用greenlet、yield、asyncio、async/await等技术实现协程编程的方法。同时还介绍了事件循环的作用和使用方法,以及如何使用await关键字和Task对象来实现异步编程。最后还提供了一些快速上手的示例代码。 ... [详细]
                  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
                  • 如何使用Java获取服务器硬件信息和磁盘负载率
                    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
                  author-avatar
                  青藤摄影876
                  这个家伙很懒,什么也没留下!
                  PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
                  Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有